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@ A spreadsheet system. 

@ A spreadsheet system comprising: 

a display means for displaying a spreadsheet; 

a means for inputting relations of a plurality of cells and cell 

values of said spreadsheet: 

a means for establishing a model including a relational node 
corresponding to the inputted relation, a cell node correspond- 
ing to the cell on which said relation is satisfied, an arc linking 
said relational node with said cell node, and a description 
describing a propagating direction of a change based on the 
input of said cell value through said arc; 
a means for marking on said calculation model one path or all of 
a plurality of paths through which the changes based on the 
input of said cell value are propagated; 
a means for determining one of said paths in accordance with 
predetermined rules; 

a means for performing a recalculation based on said input cell 
value in accordance with said determined path; and 
a means for reflecting the performed result of the recalculation 
of said spreadsheet. 
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Description 

A SPREADSHEET SYSTEM 

The present invention relates to a spreadsheet system for processing data displayed on a spreadsheet, and 
particularly to the apparatus capable of recalculation in both directions. 
5 So far , there has been known a spreadsheet program language program in which a table is constructed by a 
plurality of cells prepared, for storing the data, a calculating procedure of the cell value is stored therein, and 
the other cell values are automatically calculated based on the cell value changes by the user. Such program 
as, for instance, Multiplan (Trademark) by the MICROSOFT Corp. and Lotus 1-2-3 (Trademark) by the Lotus 
Development Corp. are known. 

10 These conventional programs, however, have the following disadvantages. In these programs, the 
calculating procedure of the cell value is expressed by a function formula. Hereinafter, a cell whose value 
determination procedure is described by a function formula is called a "function value cell", and the cell 
referred to in the function formula is called a "variable value cell". Fig. 26 shows exemplified definitions of the 
function, formulas. Each of the cell names is the same as that employed in Lotus 1-2-3. At the upper row of the 

15 each cell the cell value displayed on the screen is shown. At the lower row the value defined in the cell or the 
function formula is shown. In this example, the function formula 
A1*A2 

is defined for the function value cell B1. In case the value of the variable value cell is changed, the value of the 
function value cell is automatically recalculated by reevaluating the function formula. For instance, when the 
20 value of the variable value cells A1 and A2 are changed to 5 and 16, respectively, as shown in Fig. 27, the value 
of the function value cell B1 is recalculated and 80 in calculated as the value. However, even if the value of the 
function value cell is changed, it is impossible to recalculate the value of the variable value cell. For instance, 
even rf the value of the function value cell B1 is changed to 100 as shown in Fig. 28, the values of the variable 
value cells A1 and A2 are not recalculated. The defined function formula A1 * A2 is deleted instead and the value 
25 100 is defined for the cell B1. 

In other words, the conventional technigue permits only one-way recalculation. 

It is to be noted here that although there are patent publications concerning the technology, such as PUPA 
numbers 61-138369, 61-138370 and 61-138371, they merely disclose the general tabulations and no 
bidirectional recalculations. 

30 The present invention has been made taking the foregoing circumstances into account, and has an object of 
providing a spreadsheet system having a recalculation function in both directions which recalculates the value 
of the function value cell based on the value change of the variable value cell and recalculates the value of one 
of the variable value cells based on the value change of the function value cell. 
In order to achieve the above object, the present invention produces the calculation model on the basis of 

35 the relations of the cells in the calculation procedure of the cell value. In the case where at least one change 
instruction of the cell value is given, the marking on the produced calculation model is performed to determine 
the recalculation order of the other cell value, the recalculation order is determined using the marks for the 
recalculation, and then the recalculation is performed. 
According to the present invention, by introducing the recalculation function in both, directions to the 

40 spreadsheet, a superior function is provided to the user. The features are that when any cell value is directly 
changed by the user, the other cell values are automatically recalculated, resulting in making the user's work 
using the spreadsheet easier and smoother. 

Brief Description of the Drawings: 
45 ' 

Fig. 1 is a block diagram representing one embodiment of the present invention; 

Figs. 2, 3 and 4 are drawings for explaining the calculation model utilized in the embodiment; 

Figs. 5 through 20 are 

drawings for explaining the operations of the recalculation performing section 3 and the respective 
50 sections in the above embodiment ; 

Figs. 21 

through 25 are drawings of working examples employing the above embodiment; 
and Figs. 26, 27 and 28 are drawings of the conventional technique. 
In the drawings the numbers represent the following integers :- 
55- 1 ... Input device, 2 ... Calculation model producing section, 3 ... Recalculation performing section, 4 ... Display 
control section, 5 ... CRT, 6 ... Pre-processing section, 7 ... Calculation order determining section, 8 ... 
Evaluation calculating section, 9 ... Backtrack control section 

Fig. 1 shows a processing system according to one embodiment of the present invention. This processing 
system comprises an input device 1, a calculation model generation section 2, a recalculation section 3, a 
60 display control section 4 and a CRT5. The information concerning the relation of the cells is inputted through 
the input device 1 by the user. The calculation model generation section 2 produces a calculation model on the 
basis of the inputted relation information. The details of the calculation model generation section 2 will be 
described later. A change instruction of the cell value is inputted through the input device 1 by the user. The 
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recalculation section 3 changes the corresponding cell value in accordance with the inputted change 
instruction and recalculates the other cell values by using the calculation model. The recalculation generation 
section comprises a pre-processing section 6, a' calculation order determining section 7, an evaluation 
calculating section 8 and a backtrack control section 9. The recalculation section will also be described in 
detail later. The result of the recalculation performing section 3 is displayed on the CRTS by the display control 
section 4. 

The calculation model generation section 2 produces the calculation model which will be described in (2) 
based on the information concerning the relation of the cells which are inputted by the user and will also be 
described in (1), thereby enabling the performing the recalculation in both directions. 

(1) The information concerning the relations of the cells comprises a relation formula of cell and a propagation 
constraint cell. 

The relation formula is expressed by: 
Y = f(Xi Xn) 

where Y, Xi and X n are names of cells in which Y is a function value cell and Xi (1 < l<n) Is a variable value 

cell. 

The propagation constraint cell is one of the variable value cells and is to be recalculated based on the value 
change of the function value cell. There, an inverse function for determining the value of the propagation 
constraint cell should be developed in accordance with the relation of the cells as shown: 
X k = f- 1 (Y.Xi... i Xk-i.X k+ i l „ f X n ) 
where Xk is the propagation constraint cell. 

(2) The calculation model comprises a relational node representing the relation, a cell node representing the 
cell, and an arc linked with these nodes. Each of the relational nodes is distinguished from the others by the 
inherent relation name. The relational node includes the relation formula as the data. Each of the cell nodes is 
distinguished from the others by the inherent cell name. The ceil node includes the cell value as data. The arc is 
expressed by a pair nodes consisting of the cell node and the relational node linked by the arc. The arcs are 
classified into three kinds, the first arc links the ceil node representing the function value cell with the relational 
node and its direction is from the relational node to the cell node. The second arc links the cell node 
representing the variable value cell with the relational node and its direction is from the relational node to the 
cell node. The third kind arc links the other cell node with the relational node and is not directional. The 
information concerning the cell node, the relational node and the arc is controlled, for example, so that their 
respective information is recorded in a table. 

The calculation model will be explained with reference to the drawing. Fig. 2 shows a calculation model of the 
relation f of the cells Y, Hi and X2. A pentagon 11 indicates the relational node. Rectangles 12, 13 and 14 
indicate the ceil nodes. The arc represented by the arrow from the top end of the pentagon is the arc linking 
the ceil node representing the function value cell with the relational node and the direction of the arrow 
represents the arc direction. In Fig. 2, an arc 15 corresponds to this arc and is linked with the cell node Y (Y is 
the relation value cell). The arc represented by the arrow from the base of the pentagon links the cell node 
indicating the propagation constraint cell with the relational node and the direction of the arrow indicates the 
direction of the arc. In Fig. 2, an arc 16 corresponds to this arc and is linked with the cell node X1 (X1 is the 
propagation constraint cell). The other arc from the base of the pentagon links the cell node which is not the 
propagation constraint cell but the variable value cell with the relational node. In Fig. 2, an arc 17 corresponds 
to this arc and is linked with the cell node X2 (X2 is not the propagation constraint cell, but the variable value 
cell). 

The recalculation on this calculation model is performed in accordance with the following rules. 

First, in case attention is paid to one relation, the value of the function value cell is recalculated when the 
value of the variable value cell is changed and the value of the function value cell is not changed. Fig. 3 shows 
an example of the recalculation of the relation f. In this example, since the value of the variable value cell X2 is 
changed and the value of the function value cell Y is not changed, the value of Y is recalculated. 

Second, in case attention is paid to one relation, the value of the propagation constraint cell is recalculated 
when the value of the function value cell is changed and the value of the propagation constraint cell is not 
changed. Fig. 4 shows an example of the recalculation on the relation f. In this example, since the value of the 
function value cell Y is changed and the value of the propagation constraint cell X1 is not changed, the value of 
X1 is recalculated. 

The recalculation performing portion 3 changes, in accordance with the change instruction of the cell value 
by the user, the corresponding cell value and recalculates the values of the other cells based on the calculation 
model. 

It is to be noted that the recalculation based on the relation is performed after completion of the 
recalculations for all cells for which recalculation may be required based on other relations. For instance, when 
the value of the cell A1 is changed as shown in Fig. 5, after the values of the cells B1 and B2 are recalculated in 
accordance with the relations R1 and R2, the value of the cell C1 is recalculated in accordance with the relation 
R3. 

Furthermore, the recalculation performing portion 3 copes with two problems, due to the possibility of 
recalculation in both directions, as follows: 

The first problem resides in a loop produced in the recalculation procedure. Fig. 6 shows a state of the loop 
production. Referring to Fig. 6, on performing the recalculation of the relation R1, the value of the function 
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value cell Y on the relation R1 is recalculated since the value of the cell X is changed. As a result, the 
recalculation rule stated in E2 cannot be used for the recalculation of the relation R2 since both values of the 
function value cell Y and the propagation constraint cell X have already been changed. In order to cope with 
such case, the recalculation section determines whether the relation formula is satisfied or not when both 
Values of the function value ceil and the propagation constraint cell are changed. When the relation formula is 
not satisfied, this fact is reported to the user. 

The second problem is that the recalculation method varies depending upon the order of the relation on 
which the recalculation is performed. In Fig. 7, for instance, since the values of the cells A1 and A2 are 
changed, if the recalculation on the relation R1 is performed first, the value Y of the function value cell Y on the 
relation R1 is recalculated by using the relation formula of the relation R1 as shown in Fig. 7(b) and, therefore, 
the value of the propagation constraint cell B2 on the relation R2 is recalculated in accordance with the relation 
R2. On the other hand, if the recalculation on the relation R2 is performed first, the value of the function value 
cell Y on the relation R2 is recalculated by using the relation formula of the relation R2 as shown in Fig. 7(c) and 
the value of the propagation constraint cell B1 on the relation R1 is recalculated in accordance with the relation 
R1. In order to cope with this case, when the recalculation method varies depending upon the order of the 
relation on which the recalculation is performed, the recalculation section records each cell value, and selects 
one relation on which the recalculation should be performed to continue the recalculation. When the backtrack 
is driven thereafter, the other relations are selected and the recalculation is continued after being returned to 
the state where each cell value was recorded. 

The recalculation section 3 comprises, as shown in Fig. 1 , the pre-processing section 6, the calculation 
order determining section 7, the evaluation calculating section 8 and the backtrack control section 9. On 
inputting the change instruction of the cell value by the user, the pre-processing section 6 performs the 
marking on the calculation model 2 to investigate all cells which may possibly be changed during the 
recalculation procedure. Then, the calculation order determining section 7 determines the recalculation order 
of the cell value by using the marks attached in the pre-processing section 6 and the evaluation calculating 
section 8 recalculates the cell value. The backtrack control section 9 records each cell value when the 
recalculation method varies depending upon the order of the relation on which the recalculation is performed 
and returns each cell value to the recorded original value when the backtrack is driven. The details of each 
portion will be described below. 

The pre-processing section 6 attaches, in response to the input of the change instruction of the cell value by 
the user, a mark, which will be described below, on the calculation model to investigate all cells which may 
possibly be changed during the recalculation procedure. There are three kinds of marks, such as M-cell, Input 
arc and Output arc, as shown in Table 1. 

The mark M-cell is used for judging whether the cell value is changed or not. The mark Input arc is used for 
identifying the cell whose value may possibly be changed due to the reasons other than the recalculation on 
that relation. The mark of Output arc is used for identifying the cell whose value may possibly be changed due 
to the recalculation of that relation. 
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Table 1 



Mark Name Contents of the Mark 



M-cell attached to the cell node to be the 

object of the change instruction by the 
user or to the cell node on which recal- 
culation has been performed. 

Input-arc attached to the arc linking the relational 
node with the cell node to be the object 
of the change instruction by the user or 
with the cell node linked with the arc 
having a mark of Output arc on the other 
relations. The Input arc's direction is 
from the start point of the cell node to 
the end point of the relational node. 

Output arc attached to the arc linking the cell node 
to be recalculated with the relational 
node when the cell node linked with the 
arc which is marked with Input arc is 
changed. The Output arc's direction is 
from the start point of the relational 
node to the end point of the cell node. 



The pre-processing section 6 first deletes, when the change instruction is inputted by the user, ait of the 
marks M-cell, Input arc and Output arc on the calculation model, changes the value of the cell node to be 
changed by the user's change instruction to the specified value by the user and marks M-cell on that node. The 
section 6 also supplies an initializing instruction to the backtrack control section 9 and attaches the marks of 
Input arc and Output arc to all of the arcs which satisfy the marking condition. 

Fig. 8 shows a marking example on the relation Y = f(X1 t X2) wherein the propagation constraint cell is 
represented by X1. Here, when the cell X2 receives the users' change instruction, the cell X2 is marked with 
M-cell. The mark of Input arc 24 is attached to an arc 21 linking the cell node X2 with the relational node f . Now, 
when the X2 value is changed, an arc 22 linking the relational node f with the cell node Y is marked with Output 
arc 25 since X2 is the variable value cell and the cell to be recalculated is the function value cell Y. 

Fig. 9 shows the marking state where the cell node Y additionally links the arc marked with Output arc on the 
other relation in the calculation model of Fig. 8. In this case, the arc 22 between the cell node Y and the 
relational node f is marked with Input arc 26. When the value of Y is changed, an arc 23 between the relational 
node f and the cell node X1 is marked with Output arc 27 since the cell to be recalculated is the propagation 
constraint cell X1. 

Hereinafter, the cell node of the start point of Input arc is called a T-cell* on its relation and the cell of the 
end point of Output arc is called a C-cell on its relation. 
The calculation order determining secion 7 determines the order of the cells to be recalculated by using the 
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mark attached in the pre-processing section 6. The order of the ceils to be recalculated Is determined by, for 
instance, a method shown in Fig. 10. In this method, seven rules are used. The respective rules will be detailed 
below. 

The condition and action of the rule 1 are shown in Table 2. The cell whose value has been already changed 
5 never becomes an object of recalculation and, therefore, the rule 1 is used to delete the mark of Output arc 
from the arc linking the cell node which is marked with M-ceil. Fig. 1 1 shows a performing example of the rule 1 
In this example, the mark of Output arc 32 is deleted from an arc 31 linking the relational node f with the cell 
node Y since the ceil node Y is marked with M-cell. 

10 Table 2 



(Rule Name) 
* Rule 1 



20 (Condition) 

In the case where Output arc is marked on the arc 
linking the cell node marked with M-cell. 



25 



30 



35 



(Action) 

The marks of these Output arcs are deleted. 



The condition and action of the rule 2 as shown in Table 3. The rule 2 is used to decide, when there is only 
one cell which may possibly have to be the object of the recalculation, whether or not that cell is to be the 
recalculation object Fig. 12 shows a performing example of the rule 2. In this example, since there exists only 
Output arc 41, and an arc 42 having a mark of Output arc 41 which is marked with lutput arc 43, the mark of 
40 Input arc 43 is deleted. 

Table 3 

45 (Rule Name) 
Rule 2 

50 (Condition) 

In case there is an arc marked with both Output arc and Input arc 
in the arcs linking one relational node, and the arc marked with 
55 Output arc is not linked with that relational node. 



60 



(Action) 

The mark of Input arc is deleted from the arc marked with both 
Output arc and Input arc. 



65 
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The condition and action of the rule 3 are shown in -Table 4. The rule 3 is used to perform, when all of the ceils 
which have the possibility of befng changed by the other relation have been already changed, the recalculation 
on the relation. Fig. 13 shows a performing example according to rule 3. fn this example, since T-cells are X1 
and X2 and are marked with M-celf, the" value of cell node Y to which Output arc 51 directs is recalculated. 5 
Then, the Y is marked with M-cell and the marks attached to afl arcs are deleted. 

Table 4 

■ w 

(Rule Name) 
Rule 3 

15 

(Condition) 

In case all of T-cells are marked with M-cell on one relation, and 

the arc marked with Output arc is linked with its relational node. 20 

(Action) 

An instruction to perform value recalculation, by using the 25 
relation formula of the relational node, of the Cell node to which 
Output arc directs is issued to the evaluation calculating section 
8, all of the marks (Input arc and Output a*c) on the arc linked 30 
with its relational node are deleted, and the cell node whose value 
has been recalculated is marked with M-cell, 

35 



The condition and action of the rule 4 are shown in Table 5. The rule 4 is used when all of cells having the 
possibility of being changed by the other relation have already been changed and there is no cell to be the 
object of the recalculation. Fig. 14 shows a performing example according to the rule 4. In this example, T-cells 40 
are Y and X1 and are marked with M-cell. Since there is no arc marked with Output arc but an arc marked with 
Input arc in the arcs linking the relational node, the rule 4 is applied and the check is performed. All marks on 
the arcs are deleted. 

45 



50 



55 



60 



65 
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Table 5 



(Rule Name) 
Rule 4 

(Condition) 

In case all of T-cells on one relation are marked with M-cell, 
there is no arc marked with Output arc in the arcs linked with its 
relational node, and there is an arc marked with Input arc in the 
arcs linked with its relational node. 

(Action) 

The evaluation calculating section 8 is instructed to determine 
whether its relation is satisfied or not and all of the marks 
(Input arc) on the arc linked with its relational node are deleted. 



The condition and action of the rule 5 are shown in Table 6. The rule 5 is used to cope with the loop. Fig. 15 
shows a performing example according to the rule 5. In this example, since there is only one Output arc 61 as 
the arc having a mark of Output arc linked with the relational node f and the cell node X1 is marked with M-cell, 
the value of the ceil node Y is recalculated and the mark of Output arc 61 is deleted. 

Fig. 16 shows an example to cope with the loop by the rule 5. In this example, the loop is produced and, 
therefore, the value of the cell node X2 cannot be recalculated unless the value of the cell node Y is 
recalculated. In this case, by applying the rule 5 to the relation R1, the Y value is recalculated and the rule 3 
becomes applicable to the relation R2. Then, the X2 value is recalculated. Subsequently, the rule 4 is applied to 
the relation R1 to determine whether R1 is satisfied or not. 



Table 6 
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(Rule Name) 



5 



Rule 5 



(Condition) 

In case there is only one arc marked with Output arc in the arcs 
linked with one relational arc, and there is a cell node marked 



10 



with M-cell in the T-cells on its relation. 



15 



(Action) 



The evaluation calculating section 8 is instructed to recalculate 
the value of the cell node to which Output arc directs by using the 
relation formula of its relational node, its cell node is marked 



20 



with M-cell, and the mark of its Output arc is deleted. 



25 



The condition and action of the rule 6 are shown in Table 7. The rule 6 is used when the cell to be 30 
recalculated varies depending upon the order of the relation to which the rule is applied. Fig. 17 shows a 
performing example according to the rule 6. In this example, there are two Output arcs 71 and 72 marked on 
the arc linked with the relational node f . An arc 73 Is marked with Input arc 74 and a cell node X2 is marked with 
M-cell. Here, if the backtrack control section 9 permits the rule 6 to be applied to the relation f , the ceil node X1 
is marked with M-cell and the Output arc 72 is deleted. 35 

In case the cell to be recalculated varies depending upon the order of the relation to which the rule is 
applied, further recalculation cannot be performed unless the recalculation of the cell value on one of the 
relations is forcedly performed. In the case of Fig. 18, for instance, the recalculation cannot be continued 
unless the recalculation on the relation R1 or R2 is forcedly performed. Here, by applying the rule 6 to R1 as 
shown In Fig. 18(a), the rule may be applied as shown in the drawing thereafter. 40 

Consequently, the value of Y is recalculated from R1 and the value of B2 is recalculated from R2.Then, at the 
time when the state is returned to that before the rule 6 is applied to R1 by backtracking, the value of Y is 
recalculated from R2 by applying the rule 6 to R2 as shown in Fig. 18(b) and the value of B1 is recalculated from 
R1. 



45 



50 



55 



60 



65 



Table 7 
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(Rule Name) 
Rule 6 



10 (Condition) 

In case there are two arcs linked with one relational node and 
marked with Output arc, and one of which is marked with Input arc, 
/5 there is a cell node marked with M-cell in T-cells on its relation, 

and the backtrack control section 9 permits the application of the 
rule 6 to its relation. 

20 

(Action) 

The backtrack control section 9 is informed that the rule 6 has 
25 been applied to its relation, the cell node linked with the arc 

having a mark of only Output arc is marked with M-cell, and the 
mark of Output arc is deleted from its arc. 

30 



The condition and action of the rule 7 are shown in Table 8. The rule 7 is applied when the object cell to be 
recalculated varies depending upon the order of the relation to which the rule is applied and the loop is 
35 produced. Fig. 19 shows an example of the performance of the rule 7. In this example, both of the arcs 81 and 
82 linked with the relational node f are marked with Output arc and Input arc, and the ceil node X2 is marked 
with M-cell. When the backtrack control section 9 permits the application of the rule 7 to the relation f, Output 
arc 83 is deleted. 

In Fig. 20, the object ceil to be recalculated varies depending upon the order of the relation to which the rule 
40 is applied and the loop is produced. In this case, by applying the rule 7 to the relation R1 , as shown in Fig. 20, 
the rule may be applied thereafter. Consequently, the value of Y is recalculated from R1 and the value of A2 is 
recalculated from R2. Then, the check of whether or not R1 is satisfied is performed. When the state is 
returned to that before the rule 7 is applied to R1 through the backtrack, by applying the rule 7 to R2 the values 
of Y and A2 are recalculated from R2 and R2, respectively, and the check of whether or not R2 is satisfied is 
45 performed. The examples thereof are omitted in Fig. 20. 



50 
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60 
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Table 8 

(Rule Name) 

Rule 7 

(Condition) 

In case there are two arcs linking with one relational node 
and marked with both Output arc and Input arc, there is a 
cell node marked with M-cell among T-cells on its relation, 
and the backtrack control section permits to the rule 7 to be 
applied to the relation. 

(Action) 

The backtrack control section is informed that the rule 7 has 
been applied to its relation, and the mark of Output arc is 
deleted from the arc linking the cell-node representing the 
propagation constraint cell with the relational node. 



The evaluation calculating section 8 evaluates the recalculation of the cell value and determines whether or 
not the relation is satisfied in response to the recalculation instruction and the evaluation instruction from the 
calculation order determining section 7. 

The recalculation of the cell value is carried out as follows. When the cell to be recalculated is the functional 
cell, the right side of the relation formula is evaluated and its value is set as the value of the function value cell. 
When the cell to be recalculated is the propagation constraint cell, an inverse function for determining the 
value of the propagation constraint cell is produced from the relation formula, its inverse function Is evaluated 
and thus the determined value is set as the value of the propagation constraint cell. 

The determination of on whether or not the relation is satisfied is performed by comparing the evaluation 
value of the right side of the relation formula with the value of the function value cell. If the two values are not 
the same, the user is warned thereof. 

The phenomenon in which the cell to be recalculated is varied depending upon the order of the relation to be 
performed is caused when there is a plurality of relations to which the rules 6 and 7 are applicable. Therefore, 
the backtrack control section 9 should record, at the time when these rules are applied to the relation, the 
state of the calculation model such as the value of each cell and the marking state, and should return to the 
state in which the state has been recorded in response to the driving of the backtrack. 

Moreover, the backtrack control section 9 should control the system so that these rules are never applied to 
the same relation more than once on the same calculation model state. 

The backtrack control section 9 has the following functions. 

The first function is to record, when the beginning of the performance of the rules 6 and 7 has been reported, 
the calculation model state thereat for the backtracking and the record of which rule is applied to which 
relation at the calculation model state (this record is called an "application record of the rule at the calculation 
model state"). 

The second function is to judge whether the rule 6 may be applied to a given relation. It investigates the 
application record of the rule at the state of the calculation model thereat, and permits the rule 6 to be applied 
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to the relation if there has been no application of the rule 6 to the relation. The application is not permitted in 
other cases. This function is used to inhibit the application of the rule 6 more than once to the same relation at 
the same calculation model state. 
The third function is to judge whether the rule 7 may be applied to a given relation. It investigates the 
5 application record of the rule at the calculation model state thereat, and permits to apply the rule 7, if there has 
been no application of the rule 7 to the relation and there has been no application of the rule 6 to any relation at 
the calculation model state, to the relation. The application of the rule 7 to the relation is not permitted in other 
cases. This function is used for two purposes. One purpose is to inhibit the application of the rule 7 to one 
relation more than once at the same calculation model state. Another purpose is to inhibit the application of 
10 the rule 7 when there is the application record of the rule 6 at the calculation model state because the rule 6 
has a higher priority than that of the rule 7. A more detailed explanation is as follows: 

First it is assumed that there are N relations to which the rule 6 is applicable at the calculation model state 
and a relation to which the rule 7 is applicable. Then, the rule 6 is first applied in consideration of the priority. 
Since there are N relations to which.the rule 6 is applicable, the rule 7 becomes applicable after performing the 
15 backtracking N times. Here, if the rule 7 is applied, although the rule 

6 was appli- cable at the calculation model state the rule 7 having a lower priority becomes being applied. 
Therefore, the application of the rule 7 should be inhibited. 

The fourth function is to perform the backtrack. The backtrack control section 9 executes the following 
processes in response to the instruction of the backtrack: 
20 (1) The actual calculation model state is returned to the state of the latest calculation model recorded 

and the process (2) is performed. The backtracking is completed if there is no record of the calculation 
model state. 

(2) The recalculation is performed if there is an applicable rule, if there is no applicable rule and the 
state record of the calculation model utilized in the process (1), all of the application records of the rules 
25 at the calculation model state thereat are deleted. Then, the process (1 ) is performed. 

The fifth function is an initializing function to delete all of the state records of calculation models and the 
application records of the rules. 

The following is a working example of the spreadsheet using the example of the loan repay calculation 
according to the present invention. 
30 When making the loan repayment schedule, the method allocating the amounts of the monthly repayments 
and the repayments by bonus must be considered. This may be easily coped with by the recalculation function 
in both directions according to the present invention. In Fig. 21 , a cell B2 represents the loan amount for 
monthly repayment; a cell B3 represents the loan amount for bonus repayment; and a cell B4, the total amount 
of the loan. Cells C2 and C3 are the repayment amounts each time for a loan of ten thousand yen. A cell D2 is a 
35 monthly repayment amount, and D3 is a repayment from each bonus. Furthermore, three relations are defined 
among these cells as shown in Fig. 21. 

It is to be assumed here that thirty million yen is necessary for the loan. On inputting that value to the cell B4 
as shown in Fig. 22, the value of the cell B2 is first recalculated in accordance with the relation (1), then the 
value of the cell D2 is recalculated in accordance with the relation (2). As a result, it is understood that one 
40 hundred and eighty thousand yen repayment each month is enough. 

Now, in order to limit the monthly repayment amount to a maximum of one hundred and twenty thousand 
yen, an input of 120,000 to the cell D2 is enough. Consequently, as shown in Fig. 23, the value of the cell B2 is 
first recalculated in accordance with the relation (2), the value of the cell B3 is then recalculated in accordance 
with the relation (1), and finally the value of the cell D3 is recalculated in accordance with the relation (3). It is 
45 understood that a payment of five hundred thousand yen from every bonus is enough in this case. 

However, if it is impossible to repay more than four hundred twenty thousand yen from each bonus, an input 
of 420,000 to the cell D3 is enough. As a result, as shown in Fig. 24, the cell B3 is first recalculated in 
accordance with the relation (3), the cell B2 is then recalculated in accordance with the relation (1), and finally 
the cell D2 is recalculated in accordance with the relation (2). It is understandable that the monthly repayment 
50 of one hundred twenty nine thousand six hundred yen is enough. 

Furthermore, if there is a limitation that the loan amount must be a multiple of one million yen and therefore 
the loan amount for the bonus is set at eight million yen, an input of 8,000,000 to the ceil E3 is enough. 
Consequently, as shown in Fig. 25, the cell B2 is first recalculated in accordance with the relation (1), the cell 
D3 is recalculated in accordance with the relation (3) and the cell D2 is then recalculated in accordance with 
55 the relation (2) . It is now understood that a monthly repayment of one hundred and thirty two thousand yen and 
a repayment of four hundred thousand yen from each bonus are enough. 
The explanation of the embodiments is now completed. 



60 Claims 

1. A spreadsheet system comprising: 
a display means for displaying a spreadsheet; 

a means for inputting relations of a plurality of cells and cell values of said spreadsheet; 
65 a means for establishing a model including a relational node corresponding to the inputted relation, a cell 
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node corresponding to the cell on which saicf relation is satisfied, an arc linking said relational node with 
said cell node, and a description describing a propagating direction of a change based on the input of said 
cell value through said arc ; 

a means for marking on said calculation model one path or all of a plurality of paths through which the 

changes based on the input of said cell value are propagated; 

a means for determining one of said paths in accordance with predetermined rules; 

a means for performing a recalculation based on said input cell value in accordance with said determined 

path; and 

a means for reflecting the performed result of the recalculation of said spreadsheet. 

2. A spreadsheet system comprising: 

a means for inputting relations of a plurality of cells and cell values of said spreadsheet ; 
a means for establishing a calculation model including a relational node corresponding to the inputted 
relation, a cell node corresponding to the cell on which said relation is satisfied, an arc linking said relative 
node with said cell node, and a descriptor describing a propagating direction of a change based on the 
input of said cell value through said arc; 

a means for marking on said calculation model on path or all of a plurality of paths through which the 

change based on the input of said celtvalue are propagated; 

a means for determining one of said paths in accordance with predetermined rules; 

a means for performing a recalculation based on said input cell value in accordance with said determined 

path; 

a means for reflecting the performed result of the recalculation on said spreadsheet; 

a means for displaying that there exists one path or a plurality of paths on which the recalculation has not 

been performed; 

a means for receiving a recalculation request in accordance with the paths not performed ; 

a means for determining one of said paths not performed in accordance with said rules; 

a means for performing the recalculation based on said cell value in accordance with the determined path 

not performed; and 

a means for reflecting the performed result of the new recalculation on said spreadsheet. 

3. A spreadsheet system according to Claim (1) or (2), wherein by using the relation concerning the cell 
which receives the performed result of the recalculation and the other cell values having said relation, the 
value to be employed of the cell receiving the performed result is developed, and this value is compared 
with said performed result/thereby making it possible to judge the unity of said recalculation. 
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© A spreadsheet system comprising: 
a display means for displaying a spreadsheet; 
a means for inputting relations of a plurality of cells 
and cell values of said spreadsheet; 
a means for establishing a model including a rela- 
tional node corresponding to the inputted relation, a 
cell node corresponding to the cell on which said 
relation is satisfied, an arc linking said relational 
node with said cell node, and a description describ- 
ing a propagating direction. of a change based on the 
input of said cell value through said arc; 
a means for marking on said calculation model one 
path or all of a plurality of paths through which the 
changes based on the input of said cell value are 
propagated; 

a means for determining one of said paths in accor- 
dance with predetermined rules; 
a means for performing a recalculation based on 
said input cell value in accordance with said deter- 
mined path; and 

a means for reflecting the performed result of the 
recalculation of said spreadsheet. 
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